(Till tentamensvakten: engelsk information behövs)

# **Exam**

# Embedded Systems I, DVA431 Västerås, 2018-06-04

Teachers: Saad Mubeen, tel: 021-103191

Adnan Causevic, tel: 021-107059

Guillermo Rodriguez-Navas, tel: 021-101356

Exam duration: 14:10 - 18:30

Help allowed: calculator, language dictionary, ruler

Points: 90 p + extra lab points

Grading: Swedish grades: ECTS grades:

0 - 54→ failed 0 - 54→ failed  $\rightarrow$  3 55 - 76 p55 - 65 $\rightarrow$  D 77 - 90 p $\rightarrow 4$ 66 - 79 $\rightarrow$  C  $91 - 100 p \rightarrow 5$ 80 - 90 $\rightarrow$  B  $91 - 100 \rightarrow A$ 

## Instructions:

- Answers should be written in English.
- <u>Short and precise</u> answers are preferred. Do not write more than necessary.
- If some <u>assumptions</u> are missing, or if you think the assumptions are unclear, write down what do <u>you assume</u> to solve the problem.
- Write <u>clearly</u>. If I cannot read it, it is wrong.

#### Good luck!!

## **Assignment 1:** (16 points)

- a) You probably heard many times that "real-time systems do not need to be fast, they need to be predictable". Explain the meaning of this sentence. (4p)
- b) Explain the main differences between a microcontroller and an FPGA. For what type of applications would you choose an FPGA? (4p)
- c) What is re-entrant code? Write a small example code that is not re-entrant? Give suggestions to make this example code re-entrant. (2p+3p+3p)

## Assignment 2: (18 points)

- a) Explain what an *optocoupler* is and how it can be used for circuit protection? (8p)
- b) Suppose you work with an AT32 microcontroller that has a 16MHz Oscillator master clock (MCK). Design a PWM signal like the one shown in the picture, having 10 Hz frequency and 40% duty cycle, by computing the following parameters. (10p)

CPRD (period value to be written in the CPRDx register)
CDTY (duty cycle value to be written in the CDTYx register)
DIV (master clock frequency linear divider to be set 2-255)

Consider that the timer used in the PWM modules is 20 bit.



## **Assignment 3:** (12 points)

- a) The build process of a microcontroller typically goes through three phases: compilation, linking and relocation, which are implemented respectively by the Compiler, the Linker and the Locator. Describe why the relocation phase is needed and how it is performed by the Locator. (8p)
- b) Arrange in the correct order the following actions implemented by an Interrupt Service Routine (ISR). (4p)
  - i. Restore CPU context
  - ii. Save CPU context
  - iii. Acknowledge interrupt
  - iv. Handle the interrupt

## **Assignment 4**: (18 points)

Consider a real-time task set consisting of five tasks, A, B, C, D, E that share four resources protected by semaphores S1, S2, S3, S4. The tasks have different priorities and they are released for execution at different release times (see table below). All tasks use their semaphores as illustrated in the column "Execution sequence" below (clock ticks are counted relative to the start of the system). The execution times of tasks are as follows: A = 9 ticks, B = 4 ticks, C = 5 ticks, D = 5 ticks and E = 4 ticks as illustrated in the table below (in the "Execution sequence" column). The deadline of each task is relative to its release time. For example, the deadline of Task D is 25, which is relative to its release time 2 (see the table below). This means that relative to time 0, the deadline of Task D is 27.

| Task | Priority    | Release<br>time | Deadline (relative to the release time) | Execution sequence |
|------|-------------|-----------------|-----------------------------------------|--------------------|
| Α    | 5 (Highest) | 10              | 11                                      | S1 S2 S3 S4        |
| В    | 4           | 8               | 16                                      | S4 S4              |
| С    | 3           | 5               | 20                                      | S3 S3              |
| D    | 2           | 2               | 25                                      | S2 S2 S2 S2        |
| E    | 1 (Lowest)  | 0               | 27                                      | S1 S1              |
|      |             |                 | Clock<br>Tick                           |                    |

For example, we can see in the table that task D has the fourth highest priority, Prio(D) = 2, it is released at time t = 2, and, once released, it will execute like described below:

- *tick 2+0*: tries to execute one clock tick without any semaphores.
- *tick* 2+1: tries to lock semaphore S2, and if ok, it enters its critical section with S2.
- tick 2+2: tries to continue its critical execution with S2.
- *tick* 2+3: tries to continue its critical execution with S2. It then releases S2 at the end of the tick.
- *tick* 2+4: tries to execute one clock tick without any semaphores.

The same reasoning applies to all other tasks.

Note that the execution scenarios for the tasks will be equal to the ones illustrated in the table above *only under the assumption* that the required semaphores are *free* when requested by a task, and the task is not pre-empted by a higher-priority task. However, from the release times above we can see that the tasks will interfere with each other. Besides, the semaphores will not be always available when requested by the tasks.

Assume the release times of the tasks, their priorities and the execution sequences from the table above:

- a) Is the task set schedulable if the *Priority Ceiling Protocol (PCP)* is used? If not, then why not? Draw the actual execution trace. You should run your trace from time t=0 until all of the tasks have completely executed once their execution sequence.
- b) Is the task set schedulable if the *Priority Inheritance Protocol (PIP)* is used? If not, then why not? Draw the actual execution trace. You should run your trace from time t=0 until all of the tasks have completely executed once their execution sequence. (9p)

#### **Assignment 5:** (10 points)

a) What are the differences among executing the software, debugging the software and testing the software?

(4p)

- b) How can one use coverage information for designing test cases? Try to elaborate your answer. (3p)
- c) "High coupling and high cohesion" is a good strategy for designing software modules in embedded systems. Do you agree or disagree with this statement? Justify your answer. (3p)

## **Assignment 6:** (16 points)

Assume three periodic tasks  $\tau_1$ ,  $\tau_2$  and  $\tau_3$  that communicate among each other by sending messages among their instances. The following is given:

#### Task T₁:

- Has execution time 250 ms and period 800 ms.
- Sends 2 messages to a message queue MSGQ during each instance (job).
- All the messages are sent at the end of execution of each job.

#### Task T2:

- Has execution time 100 ms and a period 200 ms.
- Receives 2 messages from the message queue during each instance (job).
- All the messages are read at the end of execution of each job.

#### Task T<sub>3</sub>:

- Has execution time 50 ms and a period 400 ms.
- Sends 2 messages to the message queue during each instance (job).
- All the messages are sent at the end of execution of each job.

#### MSGQ:

- The queue contains the copy of the messages (not pointers).
- Has First In First Out (FIFO) order for inserting the messages.
- When a task reads a message from the message queue, the message is removed from the queue.

#### Questions:

- a) Assume that the tasks are scheduled using the **Earliest Deadline First** algorithm. What is the minimum possible size of the message queue (counted in number of messages) such that we are able to guarantee there will always be enough space in the queue for τ1 and τ3 to insert their messages? Motivate your answer by drawing an execution trace up to one hyper period and showing the number of messages in the queue after the execution of each task instance. (8p)
- b) Assume that the tasks are scheduled using the **Shortest Job First** algorithm. What is the minimum possible size of the message queue (counted in number of messages) such that we are able to guarantee there will always be enough space in the queue for τ1 and τ3 to insert their messages? Motivate your answer by drawing an execution trace up to one hyper period and showing the number of messages in the queue after the execution of each task instance. (8p)

# **Assignment 7: (extra lab points)**

You do not need to do anything here. This is for the extra points earned at the labs. Your extra lab points will be automatically added to your total exam score.